/**
给你一个整数 x ，如果 x 是一个回文整数，返回 true ；否则，返回 false 。 

 回文数是指正序（从左向右）和倒序（从右向左）读都是一样的整数。 

 
 例如，121 是回文，而 123 不是。 
 

 

 示例 1： 

 
输入：x = 121
输出：true
 

 示例 2： 

 
输入：x = -121
输出：false
解释：从左向右读, 为 -121 。 从右向左读, 为 121- 。因此它不是一个回文数。
 

 示例 3： 

 
输入：x = 10
输出：false
解释：从右向左读, 为 01 。因此它不是一个回文数。
 

 

 提示： 

 
 -2³¹ <= x <= 2³¹ - 1 
 

 

 进阶：你能不将整数转为字符串来解决这个问题吗？ 

 Related Topics 数学 👍 2470 👎 0

*/

package com.shuzijun.leetcode.editor.cn;
public class PalindromeNumber{
    public static void main(String[] args) {
         Solution solution = new PalindromeNumber().new Solution();
         solution.isPalindrome(121);
    }
    //leetcode submit region begin(Prohibit modification and deletion)
class Solution {
    public boolean isPalindrome(int x) {
        if (x < 0)return false;
        int backupX = x;
        int y = 0;
        while (x != 0){
            y = y*10 +x%10;
            x =x/10;
        }
        return backupX == y;
//        if (x < 0) return false;
//        int[] digits = new int[10];
//        int k = 0;
//        while (x != 0){
//            digits[k] = x%10;
//            x =x/10;
//            k++;
//        }
//
//        for (int i = 0; i < k/2; i++) {
//            if (digits[i] != digits[k-i-1]){
//                return false;
//            }
//        }
//        return true;
    }
}
//leetcode submit region end(Prohibit modification and deletion)

}